<template>
  <div class="update-birthday">
    <van-datetime-picker
      class="newdate"
      v-model="currentDate"
      type="date"
      title="选择年月日"
      :min-date="minDate"
      :max-date="maxDate"
      @cancel="$emit('close')"
      @confirm="onConfirm"
    />
  </div>
</template>

<script>
// 导入编辑用户个人资料API接口
import { upDateUserProfile } from "@/api/user";
// 导入更新时间组件
import dayjs from "dayjs";
export default {
  // 组件名称
  name: "UpdateBirthday",
  // 组件参数 接收来自父组件的数据
  props: {
    value: {
      type: String,
      required: true,
    },
  },
  // 局部注册的组件
  components: {},
  // 组件状态值
  data() {
    return {
      // 年月份组件
      minDate: new Date(1988, 0, 1),
      maxDate: new Date(2050, 10, 1),
      currentDate: new Date(this.value),
    };
  },
  // 计算属性
  computed: {},
  // 侦听器
  watch: {},
  // 组件方法
  methods: {
    async onConfirm() {
      this.$toast.loading({
        message: "保存中...",
        forbidClick: true,
        duration: 0,
      });
      try {
        const currentDate = dayjs(this.currentDate).format("YYYY-MM-DD");
        await upDateUserProfile({
          birthday: currentDate,
        });
        // 更新视图
        this.$emit("input", currentDate);
        // 关闭弹层
        this.$emit("close");
        // 提示成功
        this.$toast.success("更新成功！");
      } catch (err) {
        console.log(err);
        this.$toast.fail("更新失败！");
      }
    },
  },
  // 以下是生命周期钩子   注：没用到的钩子请自行删除
  /**
   * 组件实例创建完成，属性已绑定，但DOM还未生成，$ el属性还不存在
   */
  created() {},
  /**
   * el 被新创建的 vm.$ el 替换，并挂载到实例上去之后调用该钩子。
   * 如果 root 实例挂载了一个文档内元素，当 mounted 被调用时 vm.$ el 也在文档内。
   */
  mounted() {},
};
</script> 

<style scoped lang="less">
.update-birthday {
  height: 100%;
  .van-picker {
    height: 100%;
  }
}
</style>